Wherefore, what is claimed is: 

1 . A process for encoding bi-level images, said process comprising 
using a computing apparatus to perform the following process actions: 

for each pixel location in raster order in the bi-level image, 

predicting a binary value for the pixel at a pixel location 
under consideration based on its context, wherein a context of a pixel refers to 
predicted values of a prescribed pattern of pixels preceding the pixel in raster 
order; 

determining whether the predicted pixel value matches the 
actual pixel value for the pixel location under consideration; and 

compressing the data concerning at which pixel locations the 
predicted pixel values match and do not match the actual values using a context- 
dependent, backward adaptive, Run-Length-Rice encoding technique. 

2. The process of Claim 1 , wherein the process action of predicting 
the binary value for the pixel at each pixel location in raster order, comprises the 
actions of: 

assigning a prescribed initial probability value to each of a set of 
potential context indexes, wherein a context index is a binary word comprising 
previously predicted binary values of a prescribed pattern of pixels of the bi-level 
image preceding in raster order a pixel whose value is currently being predicted, 
and wherein the initial probability value indicates the probability that the pixel 
whose value is currently being predicted has a first binary value associated with 
a first of the two colors of the bi-level image based on the predicted values of the 
prescribed pattern of pixels preceding the pixel being predicted; and 

for each pixel location in raster order in the bi-level image, 

computing the context index associated with the prescribed 
pattern of pixels preceding the pixel location under consideration, wherein pixel 



locations in the pattern that fall outside the bi-level image are considered to have 
the first binary value, 

identifying the probability value assigned to the computed 

context index, 

whenever the identified probability value indicates that the 
pixel location under consideration is more likely than not to have the first binary 
value, assigning as the predicted pixel value for that location the first binary 
value, and 

whenever the identified probability value indicates that the 
pixel location under consideration is not more likely than not to have the first 
binary value, assigning as the predicted pixel value for that location the second 
binary value associated with a second of the two colors of the bi-level image. 

3. The process of Claim 2, wherein the first binary value associated 
with the first of the two colors of the bi-level image is a 0, and the second binary 
value associated with the second of the two colors of the bi-level image is a 1 . 

4. The process of Claim 2, wherein the first of the two colors of the bi- 
level image is white, and the second of the two colors is black. 

5. The process of Claim 2, wherein the process action of assigning a 
prescribed initial probability value to each of a set of potential context indexes, 
comprises an action of assigning the same initial probability value to each 
context index, said initial probability being a number indicative of a 0.50 
probability that the pixel value has the first binary value. 

6. The process of Claim 2, further comprising a process action of 
adjusting the probability value assigned to the computed context index by 
increasing it by a prescribed amount if the predicted pixel value of the pixel 
location under consideration is assigned the first binary value and decreasing it 




by a prescribed amount if the predicted pixel value is assigned the second binary 
value. 

7. The process of Claim 6, wherein the probability values are scaled 
5 so as to range between 0 and prescribed maximum integer number, and wherein 
the process action of adjusting the probability value assigned to the computed 
context index comprises an action of making the adjustments in integer 
increments. 



10 8. The process action of Claim 7, wherein the process action of 

adjusting the probability value assigned to the computed context index further 
comprises the actions of: 

II 

jj whenever decreasing the scaled probability value would result in a 

jl value of less than 0, making the probability value 0; and 

|* 15 whenever increasing the scaled probability value would result in a 

il value of greater than the prescribed maximum minus one, making the probability 

U value equal to the prescribed maximum minus one. 

■a J 

ill 

i^l 9. The process of Claim 7, wherein the prescribed maximum integer 

; s - 20 number is eight. 

jab 

10. The process of Claim 1 , wherein the process action of determining 
whether the predicted pixel value matches the actual pixel value for the pixel 
location under consideration, comprises the actions of: 
25 comparing the predicted pixel value to the actual pixel value of the 

pixel location under consideration; and 

assigning a prediction error value to the pixel location, wherein the 
prediction error value has a first binary value if the predicted pixel value matches 
the actual pixel value and a second binary value if the predicted pixel value is 
30 different from the actual pixel value. 



41 



1 1 . The process of Claim 10, wherein the first binary value associated 
with the prediction error values is a 0, and the second binary value associated 
with the prediction error values is a 1 . 

5 1 2. The process of Claim 1 , wherein the process action of compressing 

the data concerning at which pixel locations the predicted pixel values do not 
match the actual values, comprises the actions of: 

assigning a prescribed initial lvalue to each context index, wherein 
a value is used to compute a number representing a string of consecutive, 
10 raster ordered, prediction error values having the first binary value; 

identifying the A: value assigned to the context index computed for 
the first pixel location in the bi-level image and subsequently for each pixel 
location that follows in raster order a pixel that triggered a codeword to be 
established; and 



I Jl 

II 15 for each pixel location in the bi-level image beginning with the first 
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and proceeding in raster order, 
% determining if the prediction error value assigned to the pixel 

'MS* 

Ul location under consideration has the first or second binary value, 

ill 

ijj whenever the prediction error value assigned to the pixel 

J : f 20 location under consideration has the first value, taking no action unless the 

number of preceding pixels locations for which no action has been taken equals 
the last-identified lvalue, and if it does equal this value, establishing a first type 
of codeword by representing the number of preceding pixel locations for which 
no action has been taken with a single first value, and 
25 whenever the prediction error value assigned to the pixel 

location under consideration has the second value, establishing a second type of 
codeword by representing the prediction error having the second value and the 
number of preceding pixel locations for which no action has been taken with a 
second value and a binary word indicating the number of preceding pixel 
30 locations for which no action has been taken. 
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13. The process of Claim 12, further comprising the process action of 
computing the number representing the string of consecutive, raster ordered, 
prediction error values having the first binary value from an assigned A; value 
using the equation 2*. 

5 

14. The process of Claim 12, wherein the first value associated with 
the first type of codeword is a 0, and the second value associated with the 
second type of codeword is a 1 . 

10 15. The process of Claim 12, wherein the process action of assigning a 

prescribed initial k value to each context index, comprises an action of assigning 

CI the same initial k value to each context index, said initial k value being preferably 

\}\ chosen as two. 

i.L 

'j- 

j « 15 16. The process of Claim 12, further comprising the process action of 

!j| whenever a codeword is established, adjusting the A; value assigned to the 

%t context index associated with pixel location that begins the string of prediction 

error values represented by that codeword by increasing it by a prescribed 

i j l amount if the codeword is of the first type and decreasing it by a prescribed 

|"[ 20 amount if the codeword is of the second type. 

17. The process of Claim 16, wherein the k values are scaled by 
multiplying each by a prescribed scaling factor. 

25 18. The process of Claim 1 7, wherein the prescribed amount that the 

scaled lvalues are increased or decreased depends on how many times the k 
values has been adjusted from its initial value. 

19. The process of Claim 18, wherein the prescribed scaling factor 
30 equals 16, the prescribed amount that a A; value is increased is 3, 3, 4, 5, and 6 
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for the first through fifth times it is consecutively increased, respectively, and 8 
for each time it is consecutively increased after the fifth time. 

20. The process of Claim 1 9, the prescribed amount that a k value is 
decreased is 0, 3, 6, 6, 8 and 10 for the first through sixth times it is 
consecutively decreased, respectively, and 12 for each time it is consecutively 
decreased after the sixth time. 

21 . A process for decoding a bi-level image encoded by a process that 
reduces the image data to a series of codewords from which can be derived 
prediction error values indicating whether the pixel values of each pixel location 
in the bi-level image had a first binary value or a second binary value, said 
codewords coming in two types a first of which is a first value representing a 
number of pixel locations that have a first binary prediction error value and the 
second of which comprises a second value followed by a binary word that 
indicates the number of pixel locations preceding a location having a second 
binary prediction error value that exhibit the first binary prediction error value, 
said process comprising using a computing apparatus to perform the following 
process actions: 

receiving the series of codewords; 

for each pixel location in raster order in a restoration image of the 
encoded bi-level image; 

predicting a binary value for the pixel at the pixel location 
under consideration based on its context, wherein a context of a pixel refers to 
predicted values of a prescribed pattern of pixels preceding the pixel in raster 
order, 

deriving a prediction error value for the pixel location under 
consideration from a received codeword; 

comparing in raster order the prediction error assigned to a pixel 
location of the restoration image and the predicted pixel value for that location 
using an exclusive OR process such that whenever the prediction error value is 




the first binary value the corresponding predicted pixel value is not changed, and 
whenever the prediction error value is the second binary value the corresponding 
predicted pixel value is flipped to its opposite binary value; and 

designating the result of each prediction error and predicted pixel 
5 value comparison as a restored pixel value for the associated pixel location in 
the restoration image. 

22. The process of Claim 21 , wherein the process action of predicting a 
binary value for the pixel at each pixel location, comprises the actions of: 
10 assigning a prescribed initial probability value to each of a set of 

potential context indexes which is identical to those used in encoding the bi-level 
£j image, wherein a context index is a binary word comprising previously predicted 

a! binary values of a prescribed pattern of pixels of the bi-level image preceding in 

Jjj raster order a pixel whose value is currently being predicted, and wherein the 

! jj 15 initial probability value indicates the probability that the pixel whose value is 
1j J currently being predicted has a first binary value associated with a first of the two 

P colors of a restoration image of the encoded bi-level image based on the 

!{! predicted values of the prescribed pattern of pixels preceding the pixel being 

ill 

Ml predicted; and 

j"[ 20 for each pixel location in raster order in the restoration image of the 

encoded bi-level image upon receiving the first of the series of codewords, 

computing the context index associated with the prescribed 
pattern of pixels preceding the pixel location under consideration, wherein pixel 
locations in the pattern that fall outside the bi-level image are considered to have 
25 the first binary value, 

identifying the probability value assigned to the computed 

context index, 

whenever the identified probability value indicates that the 
pixel location under consideration is more likely than not to have the first binary 
30 value, assigning as the predicted pixel value for that location the first binary 
value, and 
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whenever the identified probability value indicates that the 
pixel location under consideration is not more likely than not to have the first 
binary value, assigning as the predicted pixel value for that location the second 
binary value associated with a second of the two colors of the bi-level image. 

23. The process of Claim 22, wherein the first binary value associated 
with the first of the two colors of the bi-level image is a 0, and the second binary 
value associated with the second of the two colors of the bi-level image is a 1 . 

24. The process of Claim 22, wherein the first of the two colors of the 
bi-level image is white, and the second of the two colors is black. 

25. The process of Claim 22, further comprising a process action of 
adjusting the probability value assigned to the computed context index by 
increasing it by the prescribed amount used in encoding the bi-level image if the 
predicted pixel value of the pixel location under consideration is assigned the first 
binary value and decreasing it by the prescribed amount used in encoding the bi- 
level image if the predicted pixel value is assigned the second binary value. 

26. The process of Claim 25, wherein the probability values are scaled 
so as to range between 0 and a prescribed maximum integer number identical to 
that used in the encoding of the bi-level image, and wherein the process action 
of adjusting the probability value assigned to the computed context index 
comprises the actions of: 

making the adjustments in integer increments; 

making the probability value 0, whenever decreasing the scaled 
probability value would result in a value of less than 0; and 

making the probability value equal to the prescribed maximum 
minus one, whenever increasing the scaled probability value would result in a 
value of greater than the prescribed maximum minus one. 



27. The process of Claim 21 , wherein the process action of deriving a 
prediction error value for each pixel location in raster order in a restoration 
image, comprises the actions of: 

assigning a prescribed initial k value to each context index that is 
5 identical to the value used in encoding the bi-level image, wherein a k value is 
used to compute a number representing a string of consecutive, raster ordered, 
prediction error values having the first binary value in the same manner 
employed in encoding the bi-level image being decoded; 

determining if the last-received codeword is of the first or second 

10 type; 

whenever the last-received codeword is of the second type, 
;jj assigning prediction error values having the first binary value to the number of 

! ^ previously-unassigned pixel locations in a restoration of the encoded bi-level 

lav 

Ul image in raster order starting with the earliest non-assigned location that are 

p 15 indicated by the binary word component of the codeword and assigning a 

j " prediction error value having the second binary value to the pixel location 

i! 

i«j following those newly assigned pixel locations; and 

111 whenever the last-received codeword is of the first type, 

l it identifying the k value assigned to the context index 

W* 20 associated with the earliest pixel location in the restoration image not yet 
assigned a prediction error value, and 

assigning prediction error values having the first binary value 
to the number of previously-unassigned pixel locations that are indicated by the 
identified k value in the restoration image in raster order starting with the earliest 
25 non-assigned location. 

28. The process of Claim 27, wherein the first value associated with 
the first type of codeword is a 0, and the second value associated with the 
second type of codeword is a 1. 

30 
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29. The process of Claim 27, further comprising the process action of, 
upon completion of assigning prediction error values in connection with the 
processing of the last-received codeword, adjusting the k value assigned to the 
context index associated with pixel location that begins the string of prediction 
error values just assigned by increasing the k value by a prescribed amount 
employed in the encoding of the bi-level image being decoded if the codeword is 
of the first type and decreasing the k value by a prescribed amount employed in 
the encoding of the bi-level image being decoded if the codeword is of the 
second type. 

30. The process of Claim 29, wherein the k values are scaled by 
multiplying each by a prescribed scaling factor employed in the encoding of the 
bi-level image being decoded. 

31 . A system for encoding bi-level images, comprising: 
a general purpose computing device; and 

a computer program comprising program modules executable by 
the computing device, wherein the computing device is directed by the program 
modules of the computer program to, 

assign a prescribed initial probability value to each of a set 
of potential context indexes, wherein a context index is a binary word comprising 
previously predicted binary values of a prescribed pattern of pixels of the bi-level 
image preceding in raster order a pixel whose value is currently being predicted, 
and wherein the initial probability value indicates the probability that the pixel 
whose value is currently being predicted has a first binary value associated with 
a first of the two colors of the bi-level image based on the predicted values of the 
prescribed pattern of pixels preceding the pixel being predicted for each pixel 
location in raster order in the bi-level image, 

predict a binary value for each pixel location in raster order 
in the bi-level image by, 
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computing the context index associated with the 
prescribed pattern of pixels preceding the pixel location under consideration, 
wherein pixel locations in the pattern that fall outside the bi-level image are 
considered to have the first binary value, 
5 identifying the probability value assigned to the 

computed context index, 

assigning as the predicted pixel value for that location 
the first binary value whenever the identified probability value indicates that the 
pixel location under consideration is more likely than not to have the first binary 
10 value, 

assigning as the predicted pixel value for that location 
l t the second binary value associated with a second of the two colors of the bi-level 

pi image whenever the identified probability value indicates that the pixel location 

jsic 

i j i under consideration is not more likely than not to have the first binary value, 

"1 15 adjusting the probability value assigned to the 

i^l computed context index by increasing it by a prescribed amount if the predicted 

q pixel value of the pixel location under consideration is assigned the first binary 

value and decreasing it by a prescribed amount if the predicted pixel value is 
Ul assigned the second binary value, 

£1 20 for each pixel location in raster order in the bi-level image, 

determine whether the predicted pixel value matches the actual pixel value for 
the pixel location under consideration by, 

comparing the predicted pixel value to the actual pixel 
value of the pixel location under consideration, and 
2 5 assigning a prediction error value to the pixel location, 

wherein the prediction error value has a first binary value if the predicted pixel 
value matches the actual pixel value and a second binary value if the predicted 
pixel value is different from the actual pixel value, and 

compress the data concerning at which pixel locations the 
30 predicted pixel values do not match the actual values using a bi-level image 
encoding technique. 
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32. A system for decoding bi-level images encoded by a process that 
reduces the image data to a series of codewords from which can be derived 
prediction error values indicating whether the pixel values of each pixel location 
in the bi-level image had a first binary value or a second binary value, said 
codewords coming in two types a first of which is a first value representing a 
number of pixel locations that have a first binary prediction error value and the 
second of which comprises a second value followed by a binary word that 
together indicate the number of pixel locations preceding a location having a 
second binary prediction error value that exhibit the first binary prediction error 
value, comprising: 

a general purpose computing device; and 

a computer program comprising program modules executable by 
the computing device, wherein the computing device is directed by the program 
modules of the computer program to, 

receive the series of codewords, 

assign a prescribed initial probability value to each of a set 
of potential context indexes which is identical to those used in encoding the bi- 
level image, wherein a context index is a binary word comprising previously 
predicted binary values of a prescribed pattern of pixels of the bi-level image 
preceding in raster order a pixel whose value is currently being predicted, and 
wherein the initial probability value indicates the probability that the pixel whose 
value is currently being predicted has a first binary value associated with a first of 
the two colors of a restoration image of the encoded bi-level image based on the 
predicted values of the prescribed pattern of pixels preceding the pixel being 
predicted; and 

predict a binary value for each pixel location in raster order 
in a restoration image of the encoded bi-level image by, upon receiving the first 
of the series of codewords, 

computing the context index associated with the 
prescribed pattern of pixels preceding the pixel location under consideration, 
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wherein pixel locations in the pattern that fall outside the bi-level image are 
considered to have the first binary value, 

identifying the probability value assigned to the 

computed context index, 
5 assigning as the predicted pixel value for that location 

the first binary value whenever the identified probability value indicates that the 
pixel location under consideration is more likely than not to have the first binary 
value, and 

assigning as the predicted pixel value for that location 
10 the second binary value associated with a second of the two colors of the bi-level 
image whenever the identified probability value indicates that the pixel location 

q under consideration is not more likely than not to have the first binary value, 

■■t\ 

1\ adjusting the probability value assigned to the computed 

iff 

context index by increasing it by the prescribed amount used in encoding the bi- 
lls 

iO 15 level image if the predicted pixel value of the pixel location under consideration is 

£ j assigned the first binary value and decreasing it by the prescribed amount used 

n in encoding the bi-level image if the predicted pixel value is assigned the second 

hj binary value, 

\ j j derive a prediction error value for each pixel location in 

p 20 raster order in a restoration image of the encoded bi-level image from a received 

jab 

codeword, 

compare in raster order the prediction error assigned to a 
pixel location of the restoration image and the predicted pixel value for that 
location using an exclusive OR process such that whenever the prediction error 
25 value is the first binary value the corresponding predicted pixel value is not 

changed, and whenever the prediction error value is the second binary value the 
corresponding predicted pixel value is flipped to its opposite binary value, and 
designate the result of each prediction error and predicted 
pixel value comparison as a restored pixel value for the associated pixel location 
30 in the restoration image. 
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33. A computer-readable medium having computer-executable 
instructions for encoding bi-level images, said computer-executable instructions 
comprising: 

for each pixel location in raster order in the bi-level image, 

predicting a binary value for the pixel at a pixel location 
under consideration based on its context, wherein a context of a pixel refers to 
predicted values of a prescribed pattern of pixels preceding the pixel in raster 
order; 

determining whether the predicted pixel value matches the 
actual pixel value for the pixel location under consideration; and 

compressing the data concerning at which pixel locations the 
predicted pixel values match and do not match the actual values by, 

assigning a prescribed initial A; value to each context index, 
wherein a lvalue is used to compute a number representing a string of 
consecutive, raster ordered, prediction error values having the first binary value, 

identifying the A; value assigned to the context index 
computed for the first pixel location in the bi-level image and subsequently for 
each pixel location that follows in raster order a pixel that triggered a codeword to 
be established, 

for each pixel location in the bi-level image beginning with 
the first and proceeding in raster order, 

determining if the prediction error value assigned to 
the pixel location under consideration has the first or second binary value, 

whenever the prediction error value assigned to the 
pixel location under consideration has the first value, taking no action unless the 
number of preceding pixels locations for which no action has been taken equals 
the last-identified lvalue, and if it does equal this k value, establishing a first type 
of codeword by representing the number of preceding pixel locations for which 
no action has been taken with a single first value, and 

whenever the prediction error value assigned to the 
pixel location under consideration has the second value, establishing a second 
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type of codeword by representing the prediction error having the second value 
and the number of preceding pixel locations for which no action has been taken 
with a second value and a binary word indicating the number of preceding pixel 
locations for which no action has been taken, and 
5 whenever a codeword is established, adjusting the k value 

assigned to the context index associated with pixel location that begins the string 
of prediction error values represented by that codeword by increasing it by a 
prescribed amount if the codeword is of the first type and decreasing it by a 
prescribed amount if the codeword is of the second type. 

10 

34. A computer-readable medium having computer-executable 
□ instructions for decoding bi-level images encoded by a process that reduces the 

image data to a series of codewords from which can be derived prediction error 

! ab values indicating whether the pixel values of each pixel location in the bi-level 

ijl 

i|j 15 image had a first binary value or a second binary value, said codewords coming 
j * j in two types a first of which is a first value representing a number of pixel 

locations that have a first binary prediction error value and the second of which 
ijij comprises a second value followed by a binary word that together indicate the 

| !{ number of pixel locations preceding a location having a second binary prediction 

O 20 error value that exhibit the first binary prediction error value, said computer- 

executable instructions comprising: 

receiving the series of codewords; 

for each pixel location in raster order in a restoration image of the 
encoded bi-level image, 
25 predicting a binary value for the pixel at the pixel location 

under consideration based on its context, wherein a context of a pixel refers to 
predicted values of a prescribed pattern of pixels preceding the pixel in raster 
order, 

deriving a prediction error value for the pixel location under 
30 consideration from a received codeword by, 
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assigning a prescribed initial A: value to each context 
index that is identical to the value used in encoding the bi-level image, wherein a 
k value is used to compute a number representing a string of consecutive, raster 
ordered, prediction error values having the first binary value in the same manner 
employed in encoding the bi-level image being decoded, 

determining if the last-received codeword is of the first 

or second type, 

whenever the last-received codeword is of the second 
type, assigning prediction error values having the first binary value to the number 
of previously-unassigned pixel locations in a restoration of the encoded bi-level 
image in raster order starting with the earliest non-assigned location that are 
indicated by the binary word component of the codeword and assigning a 
prediction error value having the second binary value to the pixel location 
following those newly assigned pixel locations, and 

whenever the last-received codeword is of the first 

type, 

identifying the k value assigned to the context 
index associated with the earliest pixel location in the restoration image not yet 
assigned a prediction error value, and 

assigning prediction error values having the 
first binary value to the number of previously-unassigned pixel locations that are 
indicated by the identified lvalue in the restoration image in raster order starting 
with the earliest non-assigned location, and 

upon completion of assigning prediction error values 
in connection with the processing of the last-received codeword, adjusting the k 
value assigned to the context index associated with pixel location that begins the 
string of prediction error values just assigned by increasing the k value by a 
prescribed amount employed in the encoding of the bi-level image being 
decoded if the codeword is of the first type and decreasing the k value by a 
prescribed amount employed in the encoding of the bi-level image being 
decoded if the codeword is of the second type; 
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comparing in raster order the prediction error assigned to a pixel 
location of the restoration image and the predicted pixel value for that location 
using an exclusive OR process such that whenever the prediction error value is 
the first binary value the corresponding predicted pixel value is not changed, and 
whenever the prediction error value is the second binary value the corresponding 
predicted pixel value is flipped to its opposite binary value; 

designating the result of each prediction error and predicted pixel 
value comparison as a restored pixel value for the associated pixel location in 
the restoration image. 
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